package edu.study.ops.config;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

@Configuration
@EnableSwagger2
public class SwaggerConfig {

	@Autowired
	private OpsConstant opsConstant;

	@Bean
	public Docket createRestApi() {
		return new Docket(DocumentationType.SWAGGER_2)
				.apiInfo(apiInfo())
				.enable(opsConstant.isSwagger2Enable())
				.select()
				//扫描的路径包,设置basePackage会将包下的所有被@Api标记类的所有方法作为api
				.apis(RequestHandlerSelectors.basePackage("edu.study.ops"))
				//指定路径处理PathSelectors.any()代表所有的路径
				.paths(PathSelectors.any())
				.build();
	}

	private ApiInfo apiInfo() {
		return new ApiInfoBuilder()
				//设置文档标题(API名称)
				.title("SpringBoot中使用Swagger2构建RESTful接口")
				//文档描述
				.description("接口说明")
				//服务条款URL
				.termsOfServiceUrl("http://127.0.0.1:8080/")
				//版本号
				.version("1.0")
				.build();
	}
}